// Copyright 2017-2018 Espressif Systems (Shanghai) PTE LTD
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef _SOC_SLC_STRUCT_H_
#define _SOC_SLC_STRUCT_H_
#ifdef __cplusplus
extern "C" {
#endif

typedef volatile struct {
    union {
        struct {
            uint32_t slc0_tx_rst:            1;
            uint32_t slc0_rx_rst:            1;
            uint32_t ahbm_fifo_rst:          1;
            uint32_t ahbm_rst:               1;
            uint32_t slc0_tx_loop_test:      1;
            uint32_t slc0_rx_loop_test:      1;
            uint32_t slc0_rx_auto_wrback:    1;
            uint32_t slc0_rx_no_restart_clr: 1;
            uint32_t slc0_rxdscr_burst_en:   1;
            uint32_t slc0_rxdata_burst_en:   1;
            uint32_t slc0_rxlink_auto_ret:   1;
            uint32_t slc0_txlink_auto_ret:   1;
            uint32_t slc0_txdscr_burst_en:   1;
            uint32_t slc0_txdata_burst_en:   1;
            uint32_t slc0_token_auto_clr:    1;
            uint32_t slc0_token_sel:         1;
            uint32_t reserved16:             2;
            uint32_t slc0_wr_retry_mask_en:  1;
            uint32_t reserved19:            13;
        };
        uint32_t val;
    } conf0;
    union {
        struct {
            uint32_t frhost_bit0:                   1;
            uint32_t frhost_bit1:                   1;
            uint32_t frhost_bit2:                   1;
            uint32_t frhost_bit3:                   1;
            uint32_t frhost_bit4:                   1;
            uint32_t frhost_bit5:                   1;
            uint32_t frhost_bit6:                   1;
            uint32_t frhost_bit7:                   1;
            uint32_t rx_start:                      1;
            uint32_t tx_start:                      1;
            uint32_t rx_udf:                        1;
            uint32_t tx_ovf:                        1;
            uint32_t token0_1to0:                   1;
            uint32_t token1_1to0:                   1;
            uint32_t tx_done:                       1;
            uint32_t tx_suc_eof:                    1;
            uint32_t rx_done:                       1;
            uint32_t rx_eof:                        1;
            uint32_t tohost:                        1;
            uint32_t tx_dscr_err:                   1;
            uint32_t rx_dscr_err:                   1;
            uint32_t tx_dscr_empty:                 1;
            uint32_t host_rd_ack:                   1;
            uint32_t wr_retry_done:                 1;
            uint32_t tx_err_eof:                    1;
            uint32_t cmd_dtc:                       1;
            uint32_t rx_quick_eof:                  1;
            uint32_t host_pop_eof_err:              1;
            uint32_t reserved28:                    4;
        };
        uint32_t val;
    } slc0_int_raw;
    union {
        struct {
            uint32_t frhost_bit0:                  1;
            uint32_t frhost_bit1:                  1;
            uint32_t frhost_bit2:                  1;
            uint32_t frhost_bit3:                  1;
            uint32_t frhost_bit4:                  1;
            uint32_t frhost_bit5:                  1;
            uint32_t frhost_bit6:                  1;
            uint32_t frhost_bit7:                  1;
            uint32_t rx_start:                     1;
            uint32_t tx_start:                     1;
            uint32_t rx_udf:                       1;
            uint32_t tx_ovf:                       1;
            uint32_t token0_1to0:                  1;
            uint32_t token1_1to0:                  1;
            uint32_t tx_done:                      1;
            uint32_t tx_suc_eof:                   1;
            uint32_t rx_done:                      1;
            uint32_t rx_eof:                       1;
            uint32_t tohost:                       1;
            uint32_t tx_dscr_err:                  1;
            uint32_t rx_dscr_err:                  1;
            uint32_t tx_dscr_empty:                1;
            uint32_t host_rd_ack:                  1;
            uint32_t wr_retry_done:                1;
            uint32_t tx_err_eof:                   1;
            uint32_t cmd_dtc:                      1;
            uint32_t rx_quick_eof:                 1;
            uint32_t host_pop_eof_err:             1;
            uint32_t reserved28:                   4;
        };
        uint32_t val;
    } slc0_int_st;
    union {
        struct {
            uint32_t frhost_bit0:                   1;
            uint32_t frhost_bit1:                   1;
            uint32_t frhost_bit2:                   1;
            uint32_t frhost_bit3:                   1;
            uint32_t frhost_bit4:                   1;
            uint32_t frhost_bit5:                   1;
            uint32_t frhost_bit6:                   1;
            uint32_t frhost_bit7:                   1;
            uint32_t rx_start:                      1;
            uint32_t tx_start:                      1;
            uint32_t rx_udf:                        1;
            uint32_t tx_ovf:                        1;
            uint32_t token0_1to0:                   1;
            uint32_t token1_1to0:                   1;
            uint32_t tx_done:                       1;
            uint32_t tx_suc_eof:                    1;
            uint32_t rx_done:                       1;
            uint32_t rx_eof:                        1;
            uint32_t tohost:                        1;
            uint32_t tx_dscr_err:                   1;
            uint32_t rx_dscr_err:                   1;
            uint32_t tx_dscr_empty:                 1;
            uint32_t host_rd_ack:                   1;
            uint32_t wr_retry_done:                 1;
            uint32_t tx_err_eof:                    1;
            uint32_t cmd_dtc:                       1;
            uint32_t rx_quick_eof:                  1;
            uint32_t host_pop_eof_err:              1;
            uint32_t reserved28:                    4;
        };
        uint32_t val;
    } slc0_int_ena;
    union {
        struct {
            uint32_t frhost_bit0:                   1;
            uint32_t frhost_bit1:                   1;
            uint32_t frhost_bit2:                   1;
            uint32_t frhost_bit3:                   1;
            uint32_t frhost_bit4:                   1;
            uint32_t frhost_bit5:                   1;
            uint32_t frhost_bit6:                   1;
            uint32_t frhost_bit7:                   1;
            uint32_t rx_start:                      1;
            uint32_t tx_start:                      1;
            uint32_t rx_udf:                        1;
            uint32_t tx_ovf:                        1;
            uint32_t token0_1to0:                   1;
            uint32_t token1_1to0:                   1;
            uint32_t tx_done:                       1;
            uint32_t tx_suc_eof:                    1;
            uint32_t rx_done:                       1;
            uint32_t rx_eof:                        1;
            uint32_t tohost:                        1;
            uint32_t tx_dscr_err:                   1;
            uint32_t rx_dscr_err:                   1;
            uint32_t tx_dscr_empty:                 1;
            uint32_t host_rd_ack:                   1;
            uint32_t wr_retry_done:                 1;
            uint32_t tx_err_eof:                    1;
            uint32_t cmd_dtc:                       1;
            uint32_t rx_quick_eof:                  1;
            uint32_t host_pop_eof_err:              1;
            uint32_t reserved28:                    4;
        };
        uint32_t val;
    } slc0_int_clr;
    uint32_t reserved_14;
    uint32_t reserved_18;
    uint32_t reserved_1c;
    uint32_t reserved_20;
    union {
        struct {
            uint32_t slc0_rx_full:    1;
            uint32_t slc0_rx_empty:   1;
            uint32_t slc0_rx_buf_len:12;
            uint32_t reserved14:     18;
        };
        uint32_t val;
    } rx_status;
    union {
        struct {
            uint32_t rxfifo_wdata:      9;
            uint32_t reserved9:         7;
            uint32_t rxfifo_push:       1;
            uint32_t reserved17:       15;
        };
        uint32_t val;
    } slc0_rxfifo_push;
    uint32_t reserved_2c;
    union {
        struct {
            uint32_t slc0_tx_full:  1;
            uint32_t slc0_tx_empty: 1;
            uint32_t reserved2:    30;
        };
        uint32_t val;
    } tx_status;
    union {
        struct {
            uint32_t txfifo_rdata:     11;
            uint32_t reserved11:        5;
            uint32_t txfifo_pop:        1;
            uint32_t reserved17:       15;
        };
        uint32_t val;
    } slc0_txfifo_pop;
    uint32_t reserved_38;
    union {
        struct {
            uint32_t addr:               20;
            uint32_t reserved20:          8;
            uint32_t stop:                1;
            uint32_t start:               1;
            uint32_t restart:             1;
            uint32_t park:                1;
        };
        uint32_t val;
    } slc0_rx_link;
    union {
        struct {
            uint32_t addr:               20;
            uint32_t reserved20:          8;
            uint32_t stop:                1;
            uint32_t start:               1;
            uint32_t restart:             1;
            uint32_t park:                1;
        };
        uint32_t val;
    } slc0_tx_link;
    uint32_t reserved_44;
    uint32_t reserved_48;
    union {
        struct {
            uint32_t slc0_intvec:        8;
            uint32_t reserved8:         24;
        };
        uint32_t val;
    } intvec_tohost;
    union {
        struct {
            uint32_t wdata:               12;
            uint32_t wr:                   1;
            uint32_t inc:                  1;
            uint32_t inc_more:             1;
            uint32_t reserved15:           1;
            uint32_t token0:              12;
            uint32_t reserved28:           4;
        };
        uint32_t val;
    } slc0_token0;
    union {
        struct {
            uint32_t wdata:               12;
            uint32_t wr:                   1;
            uint32_t inc:                  1;
            uint32_t inc_more:             1;
            uint32_t reserved15:           1;
            uint32_t token1:              12;
            uint32_t reserved28:           4;
        };
        uint32_t val;
    } slc0_token1;
    uint32_t reserved_58;
    uint32_t reserved_5c;
    union {
        struct {
            uint32_t slc0_check_owner:     1;
            uint32_t slc0_tx_check_sum_en: 1;
            uint32_t slc0_rx_check_sum_en: 1;
            uint32_t cmd_hold_en:          1;
            uint32_t slc0_len_auto_clr:    1;
            uint32_t slc0_tx_stitch_en:    1;
            uint32_t slc0_rx_stitch_en:    1;
            uint32_t reserved7:           12;
            uint32_t host_int_level_sel:   1;
            uint32_t reserved20:           2;
            uint32_t clk_en:               1;
            uint32_t reserved23:           9;
        };
        uint32_t val;
    } conf1;
    uint32_t slc0_state0;                                 /**/
    uint32_t slc0_state1;                                 /**/
    uint32_t reserved_6c;
    uint32_t reserved_70;
    union {
        struct {
            uint32_t txeof_ena:          6;
            uint32_t reserved6:          2;
            uint32_t fifo_map_ena:       4;
            uint32_t slc0_tx_dummy_mode: 1;
            uint32_t hda_map_128k:       1;
            uint32_t reserved14:         2;
            uint32_t tx_push_idle_num:  16;
        };
        uint32_t val;
    } bridge_conf;
    uint32_t slc0_to_eof_des_addr;                        /**/
    uint32_t slc0_tx_eof_des_addr;                        /**/
    uint32_t slc0_to_eof_bfr_des_addr;                    /**/
    uint32_t reserved_84;
    uint32_t reserved_88;
    uint32_t reserved_8c;
    union {
        struct {
            uint32_t mode:         3;
            uint32_t reserved3:    1;
            uint32_t addr:         2;
            uint32_t reserved6:   26;
        };
        uint32_t val;
    } ahb_test;
    union {
        struct {
            uint32_t cmd_st:          3;
            uint32_t reserved3:       1;
            uint32_t func_st:         4;
            uint32_t sdio_wakeup:     1;
            uint32_t reserved9:       3;
            uint32_t bus_st:          3;
            uint32_t reserved15:      1;
            uint32_t func1_acc_state: 5;
            uint32_t reserved21:     11;
        };
        uint32_t val;
    } sdio_st;
    union {
        struct {
            uint32_t slc0_token_no_replace:   1;
            uint32_t slc0_infor_no_replace:   1;
            uint32_t slc0_rx_fill_mode:       1;
            uint32_t slc0_rx_eof_mode:        1;
            uint32_t slc0_rx_fill_en:         1;
            uint32_t slc0_rd_retry_threshold:11;
            uint32_t reserved16:             16;
        };
        uint32_t val;
    } rx_dscr_conf;
    uint32_t slc0_txlink_dscr;                            /**/
    uint32_t slc0_txlink_dscr_bf0;                        /**/
    uint32_t slc0_txlink_dscr_bf1;                        /**/
    uint32_t slc0_rxlink_dscr;                            /**/
    uint32_t slc0_rxlink_dscr_bf0;                        /**/
    uint32_t slc0_rxlink_dscr_bf1;                        /**/
    uint32_t reserved_b4;
    uint32_t reserved_b8;
    uint32_t reserved_bc;
    uint32_t reserved_c0;
    uint32_t reserved_c4;
    uint32_t reserved_c8;
    uint32_t slc0_tx_erreof_des_addr;                     /**/
    uint32_t reserved_d0;
    union {
        struct {
            uint32_t slc0_token:12;
            uint32_t reserved12:20;
        };
        uint32_t val;
    } token_lat;
    union {
        struct {
            uint32_t wr_retry_threshold:11;
            uint32_t reserved11:        21;
        };
        uint32_t val;
    } tx_dscr_conf;
    uint32_t cmd_infor0;                                  /**/
    uint32_t cmd_infor1;                                  /**/
    union {
        struct {
            uint32_t len_wdata:             20;
            uint32_t len_wr:                 1;
            uint32_t len_inc:                1;
            uint32_t len_inc_more:           1;
            uint32_t rx_packet_load_en:      1;
            uint32_t tx_packet_load_en:      1;
            uint32_t rx_get_used_dscr:       1;
            uint32_t tx_get_used_dscr:       1;
            uint32_t rx_new_pkt_ind:         1;
            uint32_t tx_new_pkt_ind:         1;
            uint32_t reserved29:             3;
        };
        uint32_t val;
    } slc0_len_conf;
    union {
        struct {
            uint32_t len:       20;
            uint32_t reserved20:12;
        };
        uint32_t val;
    } slc0_length;
    uint32_t slc0_txpkt_h_dscr;                           /**/
    uint32_t slc0_txpkt_e_dscr;                           /**/
    uint32_t slc0_rxpkt_h_dscr;                           /**/
    uint32_t slc0_rxpkt_e_dscr;                           /**/
    uint32_t slc0_txpktu_h_dscr;                          /**/
    uint32_t slc0_txpktu_e_dscr;                          /**/
    uint32_t slc0_rxpktu_h_dscr;                          /**/
    uint32_t slc0_rxpktu_e_dscr;                          /**/
    uint32_t reserved_10c;
    uint32_t reserved_110;
    union {
        struct {
            uint32_t slc0_position:     8;
            uint32_t reserved8:        24;
        };
        uint32_t val;
    } seq_position;
    union {
        struct {
            uint32_t rx_dscr_rec_lim:     10;
            uint32_t reserved10:          22;
        };
        uint32_t val;
    } slc0_dscr_rec_conf;
    union {
        struct {
            uint32_t dat0_crc_err_cnt: 8;
            uint32_t dat1_crc_err_cnt: 8;
            uint32_t dat2_crc_err_cnt: 8;
            uint32_t dat3_crc_err_cnt: 8;
        };
        uint32_t val;
    } sdio_crc_st0;
    union {
        struct {
            uint32_t cmd_crc_err_cnt: 8;
            uint32_t reserved8:      23;
            uint32_t err_cnt_clr:     1;
        };
        uint32_t val;
    } sdio_crc_st1;
    uint32_t slc0_eof_start_des;                          /**/
    uint32_t slc0_push_dscr_addr;                         /**/
    uint32_t slc0_done_dscr_addr;                         /**/
    uint32_t slc0_sub_start_des;                          /**/
    union {
        struct {
            uint32_t rx_dscr_cnt_lat:     10;
            uint32_t reserved10:           6;
            uint32_t rx_get_eof_occ:       1;
            uint32_t reserved17:          15;
        };
        uint32_t val;
    } slc0_dscr_cnt;
    union {
        struct {
            uint32_t len_lim:     20;
            uint32_t reserved20:  12;
        };
        uint32_t val;
    } slc0_len_lim_conf;
    union {
        struct {
            uint32_t frhost_bit01:                  1;
            uint32_t frhost_bit11:                  1;
            uint32_t frhost_bit21:                  1;
            uint32_t frhost_bit31:                  1;
            uint32_t frhost_bit41:                  1;
            uint32_t frhost_bit51:                  1;
            uint32_t frhost_bit61:                  1;
            uint32_t frhost_bit71:                  1;
            uint32_t rx_start1:                     1;
            uint32_t tx_start1:                     1;
            uint32_t rx_udf1:                       1;
            uint32_t tx_ovf1:                       1;
            uint32_t token0_1to01:                  1;
            uint32_t token1_1to01:                  1;
            uint32_t tx_done1:                      1;
            uint32_t tx_suc_eof1:                   1;
            uint32_t rx_done1:                      1;
            uint32_t rx_eof1:                       1;
            uint32_t tohost1:                       1;
            uint32_t tx_dscr_err1:                  1;
            uint32_t rx_dscr_err1:                  1;
            uint32_t tx_dscr_empty1:                1;
            uint32_t host_rd_ack1:                  1;
            uint32_t wr_retry_done1:                1;
            uint32_t tx_err_eof1:                   1;
            uint32_t cmd_dtc1:                      1;
            uint32_t rx_quick_eof1:                 1;
            uint32_t host_pop_eof_err1:             1;
            uint32_t reserved28:                    4;
        };
        uint32_t val;
    } slc0_int_st1;
    union {
        struct {
            uint32_t frhost_bit01:                   1;
            uint32_t frhost_bit11:                   1;
            uint32_t frhost_bit21:                   1;
            uint32_t frhost_bit31:                   1;
            uint32_t frhost_bit41:                   1;
            uint32_t frhost_bit51:                   1;
            uint32_t frhost_bit61:                   1;
            uint32_t frhost_bit71:                   1;
            uint32_t rx_start1:                      1;
            uint32_t tx_start1:                      1;
            uint32_t rx_udf1:                        1;
            uint32_t tx_ovf1:                        1;
            uint32_t token0_1to01:                   1;
            uint32_t token1_1to01:                   1;
            uint32_t tx_done1:                       1;
            uint32_t tx_suc_eof1:                    1;
            uint32_t rx_done1:                       1;
            uint32_t rx_eof1:                        1;
            uint32_t tohost1:                        1;
            uint32_t tx_dscr_err1:                   1;
            uint32_t rx_dscr_err1:                   1;
            uint32_t tx_dscr_empty1:                 1;
            uint32_t host_rd_ack1:                   1;
            uint32_t wr_retry_done1:                 1;
            uint32_t tx_err_eof1:                    1;
            uint32_t cmd_dtc1:                       1;
            uint32_t rx_quick_eof1:                  1;
            uint32_t host_pop_eof_err1:              1;
            uint32_t reserved28:                     4;
        };
        uint32_t val;
    } slc0_int_ena1;
    uint32_t reserved_144;
    uint32_t reserved_148;
    uint32_t reserved_14c;
    uint32_t reserved_150;
    uint32_t reserved_154;
    uint32_t reserved_158;
    uint32_t reserved_15c;
    uint32_t reserved_160;
    uint32_t reserved_164;
    uint32_t reserved_168;
    uint32_t reserved_16c;
    uint32_t reserved_170;
    uint32_t reserved_174;
    uint32_t reserved_178;
    uint32_t reserved_17c;
    uint32_t reserved_180;
    uint32_t reserved_184;
    uint32_t reserved_188;
    uint32_t reserved_18c;
    uint32_t reserved_190;
    uint32_t reserved_194;
    uint32_t reserved_198;
    uint32_t reserved_19c;
    uint32_t reserved_1a0;
    uint32_t reserved_1a4;
    uint32_t reserved_1a8;
    uint32_t reserved_1ac;
    uint32_t reserved_1b0;
    uint32_t reserved_1b4;
    uint32_t reserved_1b8;
    uint32_t reserved_1bc;
    uint32_t reserved_1c0;
    uint32_t reserved_1c4;
    uint32_t reserved_1c8;
    uint32_t reserved_1cc;
    uint32_t reserved_1d0;
    uint32_t reserved_1d4;
    uint32_t reserved_1d8;
    uint32_t reserved_1dc;
    uint32_t reserved_1e0;
    uint32_t reserved_1e4;
    uint32_t reserved_1e8;
    uint32_t reserved_1ec;
    uint32_t reserved_1f0;
    uint32_t reserved_1f4;
    uint32_t date;                                     /**/
    uint32_t id;                                       /**/
} slc_dev_t;
extern slc_dev_t SLC;
#ifdef __cplusplus
}
#endif

#endif  /* _SOC_SLC_STRUCT_H_ */
